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INPUT_PORT(1) register float *Prepower; 
INPUT_PORT(2) register float *Postpower; 
INPUT_PORT(3) register float *RFgain; 
3 OUTPUT_PORT(1 ) register float *Output; /*IF AGC Gain in dB*/ 

py BLOCKFACTOR long BlockFactor; 

01 

Ed PARAMETER(1 ) float OutputlntervalWidth;/*71 dB*/ 

« PARAM ETER(2) float SetPointdBPre; /*42.2*/ 

m PARAM ETER(3) float SetPointdBPost; /*32.27 

PARAM ETER(4) float Kagc; /*0.25*/ 

Q PARAM ETER(5) float PreDropdB; /*3.0*/ 

Jf PARAMETER(6) long WaitTime; /*8 OFDM Frames!!*/ 

2} STATE float oldoutput; 

£ STATE float oldrfgain; 

fJS STATE long counter; 

#include <math.h> 



void init ofdmagccontrol2() 

{ FIG. 11A 

/*initialize Sum*/ 
oldoutput = 0.0; 
counter = WaitTime; 
} 



void ofdmagccontrol2() 
{ 

register float dbinpre, dbinpost, err, rfgain, output; 
float Halflnterval = (OutputlntervalWidth / 2.0); 
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LOOP(BlockFactor) 

printf(" IFbeg \n M ); 

dbinpre = *Prepower++; dbinpost = *Postpower++; 
rfgain = *RFgain++; 

printf("prepower = %f, post = %f, rfgain = %f\n", dbinpre, dbinpost, rfgain); 
if((rfgain - oldrfgain)! = 0.0) 

{ 

output = oldoutput - (rfgain - oldrfgain); 

printf("ifgain = -rfdiff = %f, oldrfgain = %f\n", output, oldrfgain); 

} 

else if ((SetPointdBPre-PreDropdB - dbinpre <= 0.0) && (counter >= WaitTime)) 
{ 

output = oldoutput - (PreDropdB + 2.0); 
printffifgain = due to Pre = %f\n'\ - PreDropdB); 
counter = 0; 

} 

else 

{ 

counter++; 

if(SetPointdBPre - dbinpre < SetPointdBPost - dbinpost) 
err = SetPointdBPre - dbinpre; 

else 

err = SetPointdBPost - dbinpost; 
err = Kagc*err; 
output = oldoutput + err; 
printffoutput = %f\n M , output); 
} 

if(output >= Half Interval) 

output = Halflnterval; 
else if (output <= -Halflnterval) Flf* 1 1 R 

output = -Halflnterval; ■ lw. D 

else 

output = output; 

*Output++ = output; 
oldrfgain = rfgain; 
oldoutput = output; 

printff 1 Fend \n"); 

ENDLOOP 
} 



